<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "../common/link.ftl">
    <script>
        $(function () {
            //编辑时才执行
            if (${employee???c}){
                $('html').one('mouseover',function() {
                    //每次打开页面后都会进行一次校验，而且只校验一次
                    $('#editForm').data("bootstrapValidator").validate();
                });
            }
            // 给form表单设置验证插件
            $("#editForm").bootstrapValidator({
                fields:{ // 配置要验证的字段
                    name:{
                        validators:{ // 验证的规则
                            notEmpty:{ // 不能为空
                                message:"用户名必填" // 错误时的提示信息
                            },
                            // 远程验证
                            remote: {
                                type: 'POST', // 请求方式
                                url: '/employee/checkName.do', // 请求地址
                                data: function() {  //自定义提交参数，默认只会提交当前用户名input的参数
                                    return {
                                        id: $('[name="id"]').val(),
                                        name: $('[name="name"]').val()
                                    };
                                },
                                message: '用户名已经存在', // 验证不通过时的提示信息
                                delay: 500 // 输入内容1秒后发请求
                            }
                        }
                    },
                    password:{
                        validators:{
                            notEmpty:{
                                message:"密码必填"
                            },
                            identical: { // 两个字段的值必须相同
                                field: 'repassword',
                                message: '两次输入的密码必须相同'
                            }
                        }
                    },
                    repassword:{
                        validators:{
                            notEmpty:{
                                message:"密码必填"
                            },
                            identical: { // 两个字段的值必须相同
                                field: 'password',
                                message: '两次输入的密码必须相同'
                            }
                        }
                    },
                    email: {
                        validators: {
                            emailAddress: {} //邮箱格式
                        }
                    },
                    age:{
                        validators: {
                            between: { //数字的范围
                                min: 0,
                                max: 100
                            }
                        }
                    }
                }
            }).on('success.form.bv', function() { // 表单所有数据验证通过后执行里面的代码
                // 该插件是在表单以这种方式提交前开始验证,所有不能使用否则一直循环
                // $("#editForm").submit();
                // 提交异步表单
                $("#editForm").ajaxSubmit(function (data){
                    if(data.success){
                        $.messager.alert("操作成功","1s后自动关闭");
                        window.setTimeout(function () {
                            // 跳转回列表
                            window.location.href = "/employee/list.do";
                        },1000)
                    }else{
                        $.messager.popup(data.msg)
                    }
                })
            });
        })
    </script>
</head>
<body class="hold-transition skin-blue sidebar-mini">
<div class="wrapper">
    <#include "../common/navbar.ftl">
    <!--菜单回显-->
    <#--<c:set var="currentMenu" value="employee"/>-->
    <#assign currentMenu="employee">
    <#include "../common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate.do" method="post" id="editForm">
                    <input type="hidden" value="${(employee.id)!}" name="id" >
                    <div class="form-group" style="margin-top: 10px;">
                        <label for="name" class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="name" name="name" value="${(employee.name)!}"
                                   placeholder="请输入用户名">
                        </div>
                    </div>
                    <#--<c:if test="${empty employee}">-->
                    <#-- employee?? 员工不为空则true 取反,没有员工对象则是添加要显示密码-->
                <#if !employee??>
                    <div class="form-group">
                        <label for="password" class="col-sm-2 control-label">密码：</label>
                        <div class="col-sm-6">
                            <input type="password" class="form-control" id="password" name="password" placeholder="请输入密码">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                        <div class="col-sm-6">
                            <input type="password" class="form-control" id="repassword" name="repassword" placeholder="再输入一遍密码">
                        </div>
                    </div>
                </#if>
                    <#--</c:if>-->
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="email" name="email" value="${(employee.email)!}" placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="age" name="age" value="${(employee.age)!}" placeholder="请输入年龄">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <#--<c:forEach items="${departments}" var="d">-->
                                <#list departments! as d>
                                    <option value="${d.id}">${d.name}</option>
                                </#list>
                               <#-- </c:forEach>-->
                                <script>
                                    $("#dept").val(${(employee.dept.id)!})
                                </script>
                            </select>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6"style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox">
                                <#--<c:if test="${employee.admin}">-->
                                <#if employee?? && employee.admin!>
                                    <script>
                                        $("#admin").prop("checked", true);
                                    </script>
                                </#if>
                                <#--</c:if>-->
                                <script>
                                    $(function () {
                                        var roleDiv; // 临时保存角色的div
                                        // 页面加载完查询是不是超管
                                        var checked = $("#admin").prop('checked');
                                        if(checked){
                                            //删除角色的div
                                            roleDiv = $("#role").detach();
                                        }
                                        // 页面加载完后给超管选项添加点击事件
                                        $("#admin").click(function () {
                                            // 判断是否是选中
                                            var checked = $(this).prop('checked');
                                            if(checked){
                                                // 删除角色的div
                                                roleDiv = $("#role").detach();
                                            }else{
                                                // 恢复角色div,加到超管的后面
                                                $("#adminDiv").after(roleDiv);
                                            }
                                        })
                                        // 角色去重
                                        var ids = [];
                                        // 获取已有的角色id(右边),存入数组
                                        $(".selfRoles > option").each(function (i, ele) {
                                            ids.push( $(ele).val());
                                        })
                                        // 遍历所有的角色(左边)
                                        $(".allRoles > option").each(function (i, ele) {
                                            // 判断是否存在右边,如果是就删除掉自己
                                            var id = $(ele).val();
                                            if($.inArray(id,ids) != -1){
                                                $(ele).remove();
                                            }
                                        })
                                    })
                                </script>
                        </div>
                    </div>
                    <div class="form-group " id="role">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                    <#--<c:forEach items="${roles}" var="r">-->
                                    <#list roles! as r>
                                        <option value="${r.id}">${r.name}</option>
                                    </#list>
                                    <#--</c:forEach>-->
                                </select>
                            </div>
                            <script>
                                /**
                                 *实现选中移动
                                 * @param src 源class
                                 * @param target 目标class
                                 */
                                function moveSelected(src , target) {
                                    $("."+target).append($("."+src+">option:selected"));
                                }
                                /**
                                 *实现全部移动
                                 * @param src 源class
                                 * @param target 目标class
                                 */
                                function moveAll(src , target) {
                                    $("."+target).append($("."+src+">option"));
                                }
                            </script>
                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>
                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <#--<c:forEach items="${employee.roles}" var="r" >-->
                                    <#list (employee.roles)! as r>
                                        <option value="${r.id}">${r.name}</option>
                                    </#list>
                                    <#--</c:forEach>-->
                                </select>
                            </div>
                        </div>
                    </div>
                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button id="submitBtn" type="button" class="btn btn-primary">保存</button>
                            <button type="reset" class="btn btn-danger">重置</button>
                        </div>
                    </div>
                </form>
                <script>
                    // 取消按钮的自动提交表单,改为button
                    $(function () {
                        //  设置点击事件
                        $("#submitBtn").click(function () {
                            //  把右边的option全部选中
                            $(".selfRoles > option").prop("selected", true);
                            //  提交表单
                            $("#editForm").submit();
                        })
                    })
                </script>

            </div>
        </section>
    </div>
    <#include "../common/footer.ftl">
</div>
</body>
</html>
